<template>
	<el-card>
		<el-tabs v-model="activeName">
			<el-tab-pane label="基本信息" name="basic">
				<basic-info-form ref="basicInfo" :info="info"/>
			</el-tab-pane>
			<el-tab-pane label="字段信息" name="columnInfo">
				<el-table ref="dragTable" :data="columns" :max-height="tableHeight" row-key="columnId">
					<el-table-column label="序号" min-width="5%" type="index"/>
					<el-table-column
							:show-overflow-tooltip="true"
							label="字段列名"
							min-width="10%"
							prop="columnName"
					/>
					<el-table-column label="字段描述" min-width="10%">
						<template #default="scope">
							<el-input v-model="scope.row.columnComment"></el-input>
						</template>
					</el-table-column>
					<el-table-column
							:show-overflow-tooltip="true"
							label="物理类型"
							min-width="10%"
							prop="columnType"
					/>
					<el-table-column label="Java类型" min-width="11%">
						<template #default="scope">
							<el-select v-model="scope.row.javaType">
								<el-option label="Long" value="Long"/>
								<el-option label="String" value="String"/>
								<el-option label="Integer" value="Integer"/>
								<el-option label="Double" value="Double"/>
								<el-option label="BigDecimal" value="BigDecimal"/>
								<el-option label="Date" value="Date"/>
								<el-option label="Boolean" value="Boolean"/>
							</el-select>
						</template>
					</el-table-column>
					<el-table-column label="java属性" min-width="10%">
						<template #default="scope">
							<el-input v-model="scope.row.javaField"></el-input>
						</template>
					</el-table-column>

					<el-table-column label="插入" min-width="5%">
						<template #default="scope">
							<el-checkbox v-model="scope.row.isInsert" false-label="0" true-label="1"></el-checkbox>
						</template>
					</el-table-column>
					<el-table-column label="编辑" min-width="5%">
						<template #default="scope">
							<el-checkbox v-model="scope.row.isEdit" false-label="0" true-label="1"></el-checkbox>
						</template>
					</el-table-column>
					<el-table-column label="列表" min-width="5%">
						<template #default="scope">
							<el-checkbox v-model="scope.row.isList" false-label="0" true-label="1"></el-checkbox>
						</template>
					</el-table-column>
					<el-table-column label="查询" min-width="5%">
						<template #default="scope">
							<el-checkbox v-model="scope.row.isQuery" false-label="0" true-label="1"></el-checkbox>
						</template>
					</el-table-column>
					<el-table-column label="查询方式" min-width="10%">
						<template #default="scope">
							<el-select v-model="scope.row.queryType">
								<el-option label="=" value="EQ"/>
								<el-option label="!=" value="NE"/>
								<el-option label=">" value="GT"/>
								<el-option label=">=" value="GTE"/>
								<el-option label="<" value="LT"/>
								<el-option label="<=" value="LTE"/>
								<el-option label="LIKE" value="LIKE"/>
								<el-option label="BETWEEN" value="BETWEEN"/>
							</el-select>
						</template>
					</el-table-column>
					<el-table-column label="必填" min-width="5%">
						<template #default="scope">
							<el-checkbox v-model="scope.row.isRequired" false-label="0" true-label="1"></el-checkbox>
						</template>
					</el-table-column>
					<el-table-column label="显示类型" min-width="12%">
						<template #default="scope">
							<el-select v-model="scope.row.htmlType">
								<el-option label="文本框" value="input"/>
								<el-option label="文本域" value="textarea"/>
								<el-option label="下拉框" value="select"/>
								<el-option label="单选框" value="radio"/>
								<el-option label="复选框" value="checkbox"/>
								<el-option label="日期控件" value="datetime"/>
								<el-option label="图片上传" value="imageUpload"/>
								<el-option label="文件上传" value="fileUpload"/>
								<el-option label="富文本控件" value="editor"/>
							</el-select>
						</template>
					</el-table-column>
					<el-table-column label="字典类型" min-width="12%">
						<template #default="scope">
							<el-select v-model="scope.row.dictType" clearable filterable placeholder="请选择">
								<el-option
										v-for="dict in dictOptions"
										:key="dict.dictType"
										:label="dict.dictName"
										:value="dict.dictType">
									<span style="float: left">{{ dict.dictName }}</span>
									<span style="float: right; color: #8492a6; font-size: 13px">{{ dict.dictType }}</span>
								</el-option>
							</el-select>
						</template>
					</el-table-column>
				</el-table>
			</el-tab-pane>
			<el-tab-pane label="生成信息" name="genInfo">
				<gen-info-form ref="genInfo" :info="info" :tables="tables"/>
			</el-tab-pane>
		</el-tabs>
		<el-form label-width="100px">
			<div style="text-align: center;margin-left:-100px;margin-top:10px;">
				<el-button type="primary" @click="submitForm()">提交</el-button>
				<el-button @click="close()">返回</el-button>
			</div>
		</el-form>
	</el-card>
</template>

<script name="GenEdit" setup>
import {getGenTable, updateGenTable} from '@/api/tool/gen'
import {optionselect as getDictOptionselect} from '@/api/system/dict/type'
import basicInfoForm from './basicInfoForm'
import genInfoForm from './genInfoForm'

const route = useRoute()
const {proxy} = getCurrentInstance()

const activeName = ref('columnInfo')
const tableHeight = ref(document.documentElement.scrollHeight - 245 + 'px')
const tables = ref([])
const columns = ref([])
const dictOptions = ref([])
const info = ref({})

/** 提交按钮 */
function submitForm() {
	const basicForm = proxy.$refs.basicInfo.$refs.basicInfoForm
	const genForm = proxy.$refs.genInfo.$refs.genInfoForm
	Promise.all([basicForm, genForm].map(getFormPromise)).then(res => {
		const validateResult = res.every(item => !!item)
		if (validateResult) {
			const genTable = Object.assign({}, info.value)
			genTable.columns = columns.value
			genTable.params = {
				treeCode: info.value.treeCode,
				treeName: info.value.treeName,
				treeParentCode: info.value.treeParentCode,
				parentMenuId: info.value.parentMenuId
			}
			updateGenTable(genTable).then(res => {
				proxy.$modal.msgSuccess(res.msg)
				if (res.code === 200) {
					close()
				}
			})
		} else {
			proxy.$modal.msgError('表单校验未通过，请重新检查提交内容')
		}
	})
}

function getFormPromise(form) {
	return new Promise(resolve => {
		form.validate(res => {
			resolve(res)
		})
	})
}

function close() {
	const obj = {path: '/tool/gen', query: {t: Date.now(), pageNum: route.query.pageNum}}
	proxy.$tab.closeOpenPage(obj)
}

(() => {
	const tableId = route.params && route.params.tableId
	if (tableId) {
		// 获取表详细信息
		getGenTable(tableId).then(res => {
			columns.value = res.data.rows
			info.value = res.data.info
			tables.value = res.data.tables
		})
		/** 查询字典下拉列表 */
		getDictOptionselect().then(response => {
			dictOptions.value = response.data
		})
	}
})()
</script>
